<template>
  <div class="func-comp-form">

    <ComponentGlobalSettingForm :id="id" :compConfigData="compConfigData"></ComponentGlobalSettingForm>

    <Tabs name="main_tabs" size="small" v-model="mainTabsValue">
      <TabPane name="main_tab" tab="main_tabs" label="主配置">

        <Tabs name="main_tabs_child" size="small">
          <TabPane tab="main_tabs_child" label="基础配置">
            <Collapse value="0">
              <Panel>
                图例
                <ShowToggle class="float-right" v-model="chartOption.legend.show"></ShowToggle>
                <div slot="content">
                  <EchartsLegendConfigForm v-model="chartOption.legend"></EchartsLegendConfigForm>
                  <Form :label-width="80">
                    <FormItemPanel title="位置偏移">
                      <FormItem label="下偏移">
                        <Input size="small" v-model="chartOption.legend.bottom"/>
                      </FormItem>
                      <FormItem label="左偏移">
                        <Input size="small" v-model="chartOption.legend.left"/>
                      </FormItem>
                    </FormItemPanel>
                  </Form>
                </div>
              </Panel>
              <Panel v-if="chartOption.title">
                标题
                <ShowToggle class="float-right" v-model="chartOption.title.show"></ShowToggle>
                <div slot="content">
                  <EchartsTitleConfigForm v-model="chartOption.title"></EchartsTitleConfigForm>
                </div>
              </Panel>
              <Panel>
                其他
                <div slot="content">
                  <EchartsOtherConfigForm v-model="compConfigData"></EchartsOtherConfigForm>
                </div>
              </Panel>
            </Collapse>
          </TabPane>
          <TabPane tab="main_tabs_child" label="系列映射">
            <Button class="float-right" size="small" type="primary" @click="addSeries"><Icon type="md-add" /> 新增系列</Button>
            <div class="clearfix"></div>
            <div class="m-b-10px"></div>

            <draggable tag="Collapse" :component-data="{attrs: {accordion: true}}" :list="chartOption.series" handle=".ivu-collapse-header">
              <Panel :name="$PnUtil.uuid()" v-for="(row, index) in chartOption.series" :key="index">
                {{'系列' + (index + 1)}}
                <a href="javascript:;" class="float-right m-r-5px" style="color: #757575;" @click.stop="deleteSeries(index)"><Icon type="md-trash" /></a>
                <div slot="content">
                  <Form :label-width="100">
                    <FormItem label="颜色">
                      <PnColorPicker size="small" v-model="row.itemStyle.color" alpha recommend/>
                    </FormItem>
                    <FormItem label="柱条宽度">
                      <Tooltip content="柱条的宽度，不设时自适应，可以是绝对值例如 40 或者百分数例如 '60%'" max-width="200" placement="left">
                        <Input size="small" v-model="row.barWidth" placeholder="默认自适应"/>
                      </Tooltip>
                    </FormItem>
                    <FormItemPanel title="值标签">
                      <p>格式化</p>
                      <Alert style="padding: 8px;">如果格式化回调函数体内容为空，默认显示value值</Alert>
                      <CodeEditor v-model="row.label.formatter" :showLint="false"
                                  :placeholder="'示例：\n(params) => {\n  return params.value\n}'"></CodeEditor>
                      <FormItem label="字体颜色">
                        <PnColorPicker size="small" v-model="row.label.color" alpha recommend/>
                      </FormItem>
                      <FormItem label="字体大小">
                        <InputNumber size="small" :max="1000" :min="0" v-model="row.label.fontSize"></InputNumber>
                      </FormItem>
                    </FormItemPanel>
                  </Form>
                </div>
              </Panel>
            </draggable>
          </TabPane>
        </Tabs>

      </TabPane>
      <TabPane name="extend_tab" tab="main_tabs" label="扩展配置">
        <Container v-if="mainTabsValue == 'extend_tab'">
          <CustomOptionDocument :componentId="id"></CustomOptionDocument>
          <CodeEditor v-model="customOption" mode="json"></CodeEditor>
          <EchartsSpreadingCodeForm v-model="echartsSpreadingCode"></EchartsSpreadingCodeForm>
        </Container>
      </TabPane>
      <TabPane name="datasource_tab" tab="main_tabs" label="数据源">
        <DatasourceState v-if="mainTabsValue == 'datasource_tab'" targetComp="CategoryRatioBarChart"></DatasourceState>
      </TabPane>
      <TabPane name="interaction_tab" tab="main_tabs" label="交互">
        <Container v-if="mainTabsValue == 'interaction_tab'">

          <!--如果组件不需要支持内置交互流接收权限，可以删除下面这个组件InteractionReceive-->
          <InteractionReceive></InteractionReceive>

          <CustomJsDocument></CustomJsDocument>
          <FormItemPanel title="初始化运行脚本">
            <CodeEditor v-model="customGlobalJsCode"></CodeEditor>
          </FormItemPanel>

          <FormItemPanel title="数据项点击时运行">
            <InteractionSender :interactionKey="'itemClick'" :canAddFieldsMap="false"></InteractionSender>
            <Alert style="padding: 5px;">此脚本中，使用_this指向当前组件vm实例，通过params可获取点击项数据</Alert>
            <CodeEditor v-model="dataItemClickJsCode"></CodeEditor>
          </FormItemPanel>
        </Container>
      </TabPane>
    </Tabs>

  </div>
</template>

<script>

  import FuncCompFormMixin from '@/mixin/FuncCompFormMixin'
  import CategoryRatioBarChart from "./CategoryRatioBarChart";

  import { createHelpers } from 'vuex-map-fields';

  const { mapFields } = createHelpers({
    getterType: 'designer/getLayoutItem',
    mutationType: 'designer/updateLayoutItem',
  });

  export default {
    name: 'CategoryRatioBarChartForm', // 此名称必须填写，且必须与组件文件名相同，并且必须加上Form字符
    mixins: [FuncCompFormMixin],
    data() {
      return {}
    },
    mounted() {

    },
    methods: {
      addSeries () {
        this.chartOption.series.push(CategoryRatioBarChart.buildSeriesObj(''))
      },
      deleteSeries (index) {
        this.chartOption.series.splice(index, 1)
      }
    },
    computed: {
      ...mapFields({

        chartOption: 'component.compConfigData.chartOption'

      })
    }
  }
</script>

<style scoped>

</style>
